TouchID简易开发教程

Touch ID 简易开发教程

基础知识

支持系统和机型

iOS系统的指纹识别功能最低支持的机型为iPhone 5s,最低支持系统为iOS 8,虽然安装iOS 7系统的5s机型可以使用系统提供的指纹解锁功能,但由于API并未开放,所以理论上第三方软件不可使用。

依赖框架

1
2
LocalAuthentication.framework
#import <LocalAuthentication/LocalAuthentication.h>

注意事项

iOS 8以下版本适配时,务必进行API验证,避免调用相关API引起崩溃。

1
2
3
if(iOS8){xxx} // 系统版本验证

if ([myContext canEvaluatePolicy:LAPolicyDeviceOwnerAuthenticationWithBiometrics error:&authError])

使用类

LAContext 指纹验证操作对象

操作流程

  • 判断系统版本,iOS 8及以上版本执行-(void)authenticateUser方法,
  • 方法自动判断设备是否支持和开启Touch ID。

代码示例

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
- (IBAction)showTouchIDAlert:(id)sender {
// 1.判断是否是iOS8之后
if (!iOS8later) {
NSLog(@"版本不对不能使用TouchID");
return;
}

// 2.调用touchID的相关方法
[self authenticateUser];
}

// 鉴定用户
- (void)authenticateUser
{
// 创建指纹验证对象
LAContext *context = [[LAContext alloc] init];
NSError *yfError = nil;

// 验证设备是否支持touchID
// LAPolicyDeviceOwnerAuthenticationWithBiometrics 14年时候枚举只有这一个属性
// LAPolicyDeviceOwnerAuthentication 后来加的枚举属性
if ([context canEvaluatePolicy:LAPolicyDeviceOwnerAuthenticationWithBiometrics error:&yfError]) {
// 支持touchID
[context evaluatePolicy:LAPolicyDeviceOwnerAuthenticationWithBiometrics
localizedReason:@"XMGlocalizedReason"
reply:^(BOOL success, NSError * _Nullable error) {
if (success) {
// touchID验证成功

// 继续处理相关业务(注意线程)
}else
{
NSLog(@"%@",error.localizedDescription);
switch (error.code) {
case LAErrorSystemCancel:
{
NSLog(@"Authentication was cancelled by the system");
//切换到其他APP,系统取消验证Touch ID
break;
}
case LAErrorUserCancel:
{
NSLog(@"Authentication was cancelled by the user");
//用户取消验证Touch ID
break;
}
case LAErrorUserFallback:
{
NSLog(@"User selected to enter custom password");
[[NSOperationQueue mainQueue] addOperationWithBlock:^{
//用户选择输入密码,切换主线程处理
}];
break;
}
default:
{
[[NSOperationQueue mainQueue] addOperationWithBlock:^{
//其他情况,切换主线程处理
}];
break;
}
}
}
}];

}else
{
switch (yfError.code) {
case LAErrorTouchIDNotEnrolled:
NSLog(@"LAErrorTouchIDNotEnrolled");
break;


case LAErrorPasscodeNotSet:
NSLog(@"LAErrorPasscodeNotSet"); // 此处触发showPasscodeResetAlert方法
break;

default:
NSLog(@"Touch ID is unaviliable");
break;
}
NSLog(@"%@", yfError.localizedDescription);
}
}

/*
typedef NS_ENUM(NSInteger, LAError)
{
//授权失败
LAErrorAuthenticationFailed = kLAErrorAuthenticationFailed,

//用户取消Touch ID授权
LAErrorUserCancel = kLAErrorUserCancel,

//用户选择输入密码
LAErrorUserFallback = kLAErrorUserFallback,

//系统取消授权(例如其他APP切入)
LAErrorSystemCancel = kLAErrorSystemCancel,

//系统未设置密码
LAErrorPasscodeNotSet = kLAErrorPasscodeNotSet,

//设备Touch ID不可用,例如未打开
LAErrorTouchIDNotAvailable = kLAErrorTouchIDNotAvailable,

//设备Touch ID不可用,用户未录入
LAErrorTouchIDNotEnrolled = kLAErrorTouchIDNotEnrolled,
} NS_ENUM_AVAILABLE(10_10, 8_0);

*/

×

纯属好玩

扫码支持
扫码打赏,你说多少就多少

打开支付宝扫一扫,即可进行扫码打赏哦

文章目录
  1. 1. Touch ID 简易开发教程
    1. 1.1. 基础知识
      1. 1.1.0.1. 支持系统和机型
      2. 1.1.0.2. 依赖框架
      3. 1.1.0.3. 注意事项
      4. 1.1.0.4. 使用类
      5. 1.1.0.5. 操作流程
      6. 1.1.0.6. 代码示例